Skip to main content
Version: v2.1.0

luci_grpc_interface

summary:

This is the primary package used in the SDK. This package also allows for the bidirectional transfer of information between LUCI and the ROS ecosystem. This package's node allows for you to read sensor data as well as send remote joystick commands to the system.

This package points at a LUCI gRPC server and operates on a multi-threaded approach which will grab all specified LUCI sensor streams then pass them through a message type conversion and then publish them on ROS topics.

You are likely to always use this node if using the LUCI SDK.

Use

To run a basic interface with no IR frames you need to run ros2 run luci_grpc_interface grpc_interface_node -a <chairs-ip-address>

To run the node while streaming IR frames add the -f flag followed by the rate you would like.

Example of streaming at 5fps per camera ros2 run luci_grpc_interface grpc_interface_node -a <chairs-ip-address> -f 5

Notes:
  • The -f flag is optional and if nothing is passed in the IR frames will "stream" at 0 fps. You will still see the ros topic but no data will be shown.
  • The best way to see the IR frames is with foxglove. See the main LUCI SDK docs for more information.
  • The maximum frame rate that can be sent is 15fps. This is the rate LUCI cameras naturally stream at.
  • All requested frame rates are best effort requests. This means that LUCI will do its best to maintain the FPS but network and other factors may slow the actual observed rate. In addition any rate that is not cleanly divided into 15 will not be guaranteed. For example a rate request of 5 will be honored minus any network delay but a request of 7 will result in either 7 or 8 fps.
PackageNode
luci_grpc_interfaceluci_grpc_interface_node
Currently ImplementedTopicsSubscription / PublishMessage TypeDescription
yesluci/remote_joysticksubscriptionluci_messages::msg::LuciJoystickRemote joystick values used to drive the chair (FB: xxx, LR: xxx). Value Range: [-100, 100]
yesluci/drive_modesubscriptionluci_messages::msg::LuciDriveModeMode of chair for drive controls (USER = user drives with joystick, ENGAGED = remote command drive the chair if user is holding joystick forward, AUTO = remote commands drive chair no matter what user is doing)
yesluci/joystick_positionpublisherluci_messages::msg::LuciJoystickJoystick values of the chair (FB:xxx, LR: xxx)
noluci/chair_velocitypublishergeometry_msgs::msg::TwistLinear and angular velocity of the chair according to onboard AHRS Note: “linear velocity” will be speed not velocity
coming soonluci/all_sensor_pointspublishersensor_msgs::msg::PointCloud2Full pointcloud (All LUCI sensors)
partiallyluci/odompublishernav_msgs::msg::OdometryAHRS odom reading
yesluci/imupublisherluci_messages::msg::LuciImuRaw IMU data from the LUCI system
yesluci/ultrasonic_pointspublishersensor_msgs::msg::PointCloud2Ultrasonic pointcloud
yesluci/radar_pointspublishersensor_msgs::msg::PointCloud2Radar pointcloud
yesluci/camera_pointspublishersensor_msgs::msg::PointCloud2Camera pointcloud decimated from full resolution by 1/2 and has footbox / origin removed (~ 36,000 points)
yesluci/scalingpublisherluci_messages::msg::LuciScalingScaling percentage of each zone LUCI sees (100% => full ability to drive)
yesluci/joystick_scalingpublisherluci_messages::msg::LuciJoystickScaled Joystick values of the chair (FB:xxx, LR: xxx)
yesluci/encoderpublisherluci_messages::msg::LuciEncodersRaw Encoder data from the LUCI system
yesluci/ir_left_camerapublishersensor_msgs::msg::ImageLeft camera’s IR frame
yesluci/ir_right_camerapublishersensor_msgs::msg::ImageRight camera’s IR frame
yesluci/ir_rear_camerapublishersensor_msgs::msg::ImageRear camera’s IR frame
yesluci/left_camera_infopublisherluci_messages::msg::LuciCameraInfoLeft camera’s IR frame meta data
yesluci/right_camera_infopublisherluci_messages::msg::LuciCameraInfoRight camera’s IR frame meta data
yesluci/rear_camera_infopublisherluci_messages::msg::LuciCameraInfoRear camera’s IR frame meta data